﻿using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;

using CE.Provider;
using CE.Global;

public partial class Provider_CarInsurance_ProviderCarOccupationType : System.Web.UI.Page
{
    string PageName = "CXCI";
    string SubPageName = "CXCIDROCP";
    protected void Page_Load(object sender, EventArgs e)
    {
        if (Session[CE.Global.General.UserId] == null || Session[CE.Global.General.ProviderCompanyId] == null)
        {
            Response.Redirect("~/Provider/ProviderSecureLogin.aspx");
        }
        CheckMainPageAccess();
        CheckSubPageAccess();

        if (!Page.IsPostBack)
        {
            usrEffectivityDate.StartYear = CE.Global.General.GetUTCDateTime().Year;
            usrEffectivityDate.EndYear = CE.Global.General.GetUTCDateTime().Year + 2;

            if (Request.Params["TypeId"] != null)
            {
                int _typeid = 0;
                if (int.TryParse(Request.Params["TypeId"].ToString(), out _typeid))
                {
                    //ddlOccupationType.Text = _cxoccupationid.ToString();
                    //ddlCXOccupation_SelectedIndexChanged(this, null);
                    ShowCarOccupationType(Convert.ToInt64(Session[General.ProviderCompanyId].ToString()), _typeid);
                }
            }
        }
    }

    protected void ibtSubmit_Click(object sender, ImageClickEventArgs e)
    {
        if (Page.IsValid)
        {
             string _authcode = CE.Security.MySecurity.Encrypt(txtAuthCode.Text, true);
             if (CheckAuthCode(_authcode, 100))
             {
                 CarOccupationType _caroccupationtype = new CarOccupationType();
                 CarOccupationTypeDB _caroccupationtypedb = new CarOccupationTypeDB();

                 _caroccupationtype.CarOccupationTypeId = CheckCarOccupationType(Convert.ToInt64(Session[General.ProviderCompanyId].ToString()), Convert.ToInt32(ddlOccupationType.SelectedValue));
                 int _trantype = 1;

                 if (_caroccupationtype.CarOccupationTypeId > 0)
                 {
                     _trantype = 2;
                 }

                 _caroccupationtype.RefCEUserId = Convert.ToInt64(Session[General.UserId].ToString());
                 _caroccupationtype.ProviderCompanyId = Convert.ToInt64(Session[General.ProviderCompanyId].ToString());

                 _caroccupationtype.Description = ddlOccupationType.SelectedItem.Text;
                 _caroccupationtype.OccupationTypeRate = Convert.ToSingle(txtOccupationRate.Text);
                 _caroccupationtype.TypeId = Convert.ToInt32(ddlOccupationType.SelectedValue);
                 _caroccupationtype.Status = chkStatus.Checked;

                 if (rdoEffectivity.SelectedValue == "Yes" && usrEffectivityDate.GetDate() > CE.Global.General.GetUTCDateTime())
                 {
                     _caroccupationtype.FInfo1 = float.Parse(txtNewRate.Text);
                     _caroccupationtype.DInfo1 = usrEffectivityDate.GetDate();

                 }
                 else
                 {
                     _caroccupationtype.FInfo1 = float.Parse(txtOccupationRate.Text);
                     _caroccupationtype.DInfo1 = CE.Global.General.GetUTCDateTime();

                 }

                 _caroccupationtype.CarOccupationTypeId = _caroccupationtypedb.Insert(_caroccupationtype);
                 if (_caroccupationtype.CarOccupationTypeId > 0)
                 {
                     InsertProviderAuthTransaction(_caroccupationtype.CarOccupationTypeId, "CICarOccupationType", _trantype, 100, _authcode, _caroccupationtype.ProviderCompanyId, _caroccupationtype.RefCEUserId);
                     ProviderUpdateSave(_caroccupationtype.CarOccupationTypeId);

                     lblMessage.Text = "Updated successfully.";
                     Response.Redirect("ViewProviderCarOccupationType.aspx");
                 }
                 else
                 {
                     lblMessage.Text = "Updating failed.";
                 }
             }
             else
             {
                 lblMessage.Text = "Wrong auth code!";
             }
        }
    }

    private void ProviderUpdateSave(Int64 ProviderRefId)
    {
        ProviderUpdates _providerupdates = new ProviderUpdates();
        ProviderUpdatesDB _providerupdatesDB = new ProviderUpdatesDB();

        _providerupdates.UpdateId = 0;
        _providerupdates.CXTableId = GetCXTableId();
        _providerupdates.ProviderRefId = ProviderRefId;

        if (rdoEffectivity.SelectedValue == "Yes" && usrEffectivityDate.GetDate() > CE.Global.General.GetUTCDateTime())
        {
            //Scheduled
            _providerupdates.UpdateType = 1;
        }
        else
        {
            //Immediate
            _providerupdates.UpdateType = 0;
        }

        _providerupdates.ProviderCompanyId = Convert.ToInt64(Session[CE.Global.General.ProviderCompanyId]);
        _providerupdates.RefCEUserID = Convert.ToInt64(Session[General.UserId].ToString());

        _providerupdatesDB.Insert(_providerupdates);

    }

    private Int32 GetCXTableId()
    {
        Int32 CXID = 0;

        ProviderTableListings _tablelist = new ProviderTableListings();
        ProviderTableListingsDB _tablelistdb = new ProviderTableListingsDB();

        int ProviderType = 100; //Car Insurance
        string CXTable = "tblProviderCarOccupation";

        _tablelist = _tablelistdb.GetProviderTableListingsSingleItem(ProviderType, Convert.ToInt64(Session[CE.Global.General.ProviderCompanyId]), CXTable);

        if (_tablelist != null)
            CXID = _tablelist.CXTableId;

        return CXID;

    }

    protected Int64 CheckCarOccupationType(Int64 ProviderCompanyId, Int32 TypeId)
    {
        CarOccupationType _caroccupationtype = new CarOccupationType();
        CarOccupationTypeDB _caroccupationtypedb = new CarOccupationTypeDB();
        Int64 _retValue = 0;
        _caroccupationtype = _caroccupationtypedb.GetCarOccupationType(ProviderCompanyId, TypeId);
        if (_caroccupationtype != null)
        {
            _retValue = _caroccupationtype.CarOccupationTypeId;
        }
        return _retValue;
    }

    protected void ShowCarOccupationType(Int64 ProviderCompanyId, Int32 TypeId)
    {
        CarOccupationType _caroccupationtype = new CarOccupationType();
        CarOccupationTypeDB _caroccupationtypedb = new CarOccupationTypeDB();

        _caroccupationtype = _caroccupationtypedb.GetCarOccupationType(ProviderCompanyId, TypeId);
        if (_caroccupationtype != null)
        {
            lblCarOccupationTypeId.Text = _caroccupationtype.CarOccupationTypeId.ToString();
            ddlOccupationType.SelectedValue = _caroccupationtype.TypeId.ToString();
            txtOccupationRate.Text = _caroccupationtype.OccupationTypeRate.ToString();
            chkStatus.Checked = _caroccupationtype.Status;

            if (_caroccupationtype.DInfo1 > CE.Global.General.GetUTCDateTime())
            {
                divNewRate.Visible = true;
                txtNewRate.Text = _caroccupationtype.FInfo1.ToString();
                rdoEffectivity.SelectedValue = "Yes";
            }
            else
            {
                divNewRate.Visible = false;
                rdoEffectivity.SelectedValue = "No";
            }

            usrEffectivityDate.Day = _caroccupationtype.DInfo1.Day;
            usrEffectivityDate.Month = _caroccupationtype.DInfo1.Month;
            usrEffectivityDate.Year = _caroccupationtype.DInfo1.Year;
        }
        else
        {
            ClearFields();
        }
    }

    protected void ddlOccupationType_SelectedIndexChanged(object sender, EventArgs e)
    {
        ShowCarOccupationType(Convert.ToInt64(Session[General.ProviderCompanyId].ToString()), Convert.ToInt32(ddlOccupationType.SelectedValue));
    }

    protected void ibtBack_Click(object sender, ImageClickEventArgs e)
    {
        Response.Redirect("ViewProviderCarOccupationType.aspx");
    }

    protected void btnDelete_Click(object sender, EventArgs e)
    {
        rfvAuthCode.Validate();
        if (lblCarOccupationTypeId.Text != "0" && txtAuthCode.Text.Trim().Length > 0)
        {
            //Int64 _caryearid = CheckCarYear(Convert.ToInt32(ddlFromYear.Text), Convert.ToInt32(ddlToYear.Text), Convert.ToInt32(ddlOccupation.Text));
            Int64 _caroccupationtypeid = Convert.ToInt64(lblCarOccupationTypeId.Text);
            Int64 _refceuserid = Convert.ToInt64(Session[General.UserId].ToString());
            Int64 _providercompanyid = Convert.ToInt64(Session[General.ProviderCompanyId].ToString());

            string _authcode = CE.Security.MySecurity.Encrypt(txtAuthCode.Text, true);
            if (CheckAuthCode(_authcode, 100))
            {
                if (_caroccupationtypeid != 0)
                {
                    CarOccupationTypeDB _caroccupationtypedb = new CarOccupationTypeDB();
                    if (_caroccupationtypedb.Delete(_caroccupationtypeid, _providercompanyid))
                    {
                        InsertProviderAuthTransaction(_caroccupationtypeid, "CICarOccupationType", 3, 100, _authcode, _providercompanyid, _refceuserid);
                        Response.Redirect("ViewProviderCarOccupationType.aspx");
                    }
                    else
                    {
                        lblMessage.Text = "Deleting failed.";
                    }
                }
            }
            else
            {
                lblMessage.Text = "Wrong auth code!";
            }
        }
    }

    private void ClearFields()
    {
        lblCarOccupationTypeId.Text = "0";
        //ddlCXOccupation.Text = "-1";
        //ddlOccupationType.SelectedValue = "-1";
        txtOccupationRate.Text = "";        
        chkStatus.Checked = false;
    }
    
    protected void btnNew_Click(object sender, EventArgs e)
    {
        ddlOccupationType.SelectedValue = "-1";
        ClearFields();
    }

    public void EffectiveWhen(object sender, EventArgs e)
    {
        if (rdoEffectivity.SelectedValue == "Yes")
        {
            divNewRate.Visible = true;
        }
        else
        {
            divNewRate.Visible = false;
        }

        usrEffectivityDate.Day = CE.Global.General.GetUTCDateTime().Day;
        usrEffectivityDate.Month = CE.Global.General.GetUTCDateTime().Month;
        usrEffectivityDate.Year = CE.Global.General.GetUTCDateTime().Year;
    }

    protected bool CheckAuthCode(string strAuthCode, int intAuthCodeType)
    {
        bool _retValue = false;
        ProviderAuthCode _authcode = new ProviderAuthCode();
        ProviderAuthCodeDB _authcodedb = new ProviderAuthCodeDB();
        _authcode = _authcodedb.GetProviderAuthCode(Convert.ToInt64(Session[General.ProviderCompanyId].ToString()), intAuthCodeType, strAuthCode);
        if (_authcode != null)
        {
            _retValue = true;
        }

        return _retValue;
    }

    protected Int64 InsertProviderAuthTransaction(Int64 TransactionId, string TransactionCode, int TransactionType,
        int AuthCodeType, string AuthCode, Int64 ProviderCompanyId, Int64 RefCEUserId)
    {
        ProviderAuthTransaction _authtrans = new ProviderAuthTransaction();
        ProviderAuthTransactionDB _authtransdb = new ProviderAuthTransactionDB();

        _authtrans.TransactionId = TransactionId;
        _authtrans.TransactionCode = TransactionCode;
        _authtrans.TransactionType = TransactionType;
        _authtrans.AuthCode = AuthCode;
        _authtrans.AuthCodeType = AuthCodeType;
        _authtrans.ProviderCompanyId = ProviderCompanyId;
        _authtrans.RefCEUserID = RefCEUserId;

        _authtrans.AuthTransId = _authtransdb.Insert(_authtrans);
        return _authtrans.AuthTransId;
    }

    private void CheckMainPageAccess()
    {
        Int64 PageAccess = General.GetProviderMainPageAccess(Convert.ToInt64(Session[General.ProviderCompanyId].ToString()),
                                                        Convert.ToInt64(Session[General.UserId].ToString()), PageName);
        if (PageAccess == 0)
        {
            //Response.Redirect("~/Provider/UserMessage.aspx?errorcode=2000");
            Response.Redirect("~/Provider/UserMessage.aspx?mt=UM&ec=2000");
        }
    }

    private void CheckSubPageAccess()
    {
        Int64 PageAccess = General.GetProviderSubPageAccess(Convert.ToInt64(Session[General.ProviderCompanyId].ToString()),
                                                        Convert.ToInt64(Session[General.UserId].ToString()), SubPageName);
        if (PageAccess == 0)
        {
            //Response.Redirect("~/Provider/UserMessage.aspx?errorcode=2000");
            Response.Redirect("~/Provider/UserMessage.aspx?mt=UM&ec=2000");
        }
        else if (PageAccess == 100)
        {
            ibtSubmit.Enabled = false;
            btnNew.Enabled = false;
            btnDelete.Enabled = false;
        }
        else if (PageAccess == 200)
        {
            ibtSubmit.Enabled = true;
            btnNew.Enabled = true;
            btnDelete.Enabled = false;
        }
        else if (PageAccess == 300)
        {
            ibtSubmit.Enabled = true;
            btnNew.Enabled = true;
            btnDelete.Enabled = true;
        }
    }

}
